package cn.qihang.ssm.service;

import cn.qihang.ssm.pojo.Role;
import cn.qihang.ssm.pojo.UserInfo;
import org.springframework.security.core.userdetails.UserDetailsService;

import java.util.List;

/**
 * @Author: qihang
 * @Date: 2022/11/2 15:51
 * @Desc:
 */
public interface UserService extends UserDetailsService {


    /**
     * 查询所有用户
     * @param page
     * @param size
     * @return
     */
    List<UserInfo> findAll(Integer page, Integer size);


    /**
     * 新增用户
     * @param userInfo
     */
    void save(UserInfo userInfo);


    /**
     * 用户详情
     * @param id
     * @return
     */
    UserInfo findById(Integer id);


    /**
     * 添加用户前，查询添加的用户是谁
     * @param id
     * @return
     */
    UserInfo findUserById(Integer id);


    /**
     * 根据用户查询哪些角色是可以添加（除了本身以经有的角色以外的才可以添加）
     * @param id
     * @return
     */
    List<Role> findOtherRoles(Integer id);



    /**
     * 给用户添加角色
     * @param userId
     * @param ids
     */
    void addRoleToUser(Integer userId, Integer[] ids);


    /**
     * 删除用户
     * @param id
     */
    void deleteUser(Integer id);
}
